<!DOCTYPE html>
<html>

<head lang="en">
    <meta charset="UTF-8">
    <title>组件选项data</title>
    <script src="../vue.js"></script>
    <script src="../vue-router.js"></script>
</head>

<body>
    <div id="app">
        <p>{{todo}}</p>
        <first v-on:addcon="addtodo"></first>
        <first v-on:addcon="addtodo"></first>
    </div>
    <script>
        Vue.component('first',{
            template:'<button @click="addcon">{{con}}</button>',
            data:function(){
                return {
                    con:0
                }
            },
            methods:{
                addcon:function(){
                    this.con+=1;
                    //使用 $on(eventName) 监听事件
                    //使用 $emit(eventName) 触发事件
                    this.$emit('addcon');
                }
            }
        })
        var app = new Vue({
            el: '#app',
            data() {
                return {
                    todo:0
                }
            },
            methods:{
                addtodo:function(){
                    this.todo +=1
                }
            }
        })
    </script>
</body>

</html>